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Sir: 



Applicant requests review of the Final Rejection in the above-identified application. No 
amendments are being filed with the request. This request is being filed with a Notice of Appeal. 
The following sets forth a succinct, concise, and focused set of arguments for which the review is 
being requested. 

CLAIM STATUS 

Claims 1, 2, 3, 5, 8, 9, 10, 12, 16, 17, 18, 20-23, 25 - 28 and 30 - 40 stand rejected under 
Chen, U.S. Patent No. 6,625,807 (Chen) in view of Zucker, U.S. Patent No. 5,991,871 
(Zucker). 



REMARKS 

The following remarks provide applicants' position regarding how the claims distinguish 
over the art of record. While not discussed herein, all the arguments presented regarding 
hindsight reconstruction and suggestion to combine are maintained. 
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The present invention generally relates to an optimizing compiler that adds annotation 
information (i.e., compiler annotation) to an executable binary code file. The compiler 
annotation provides information useful for binary translators such that a binary translator does 
not have to use a heuristic approach to translate binary code. Compiler annotation identifies such 
information as function boundaries, split functions, jump table information, function addresses 
and code labels. (See e.g., application page 3, liens 1 - 9.) 

Chen discloses a method for register optimization during code translation and utilizes a 
technique that removes the time overhead for analyzing register usage and eliminates fixed 
restraints on the compiler register usage. The method for register optimization utilizes a 
compiler to produce a bit vector for each program unit (i.e., subroutine, function, and/or 
procedure). Each bit in the bit vector represents a particular caller-saved register. A bit is set if 
the compiler uses the corresponding register within that program unit. During the translation, the 
translator examines the bit vector to very quickly determine which registers are free, and 
therefore can be used during register optimization without having to save and restore the register 
values. 

Zucker discloses interfacing a binary application program to a computer system. The 
application binary interface includes linkage structures for interfacing the binary application 
program to a digital computer. A function in a relocatable shared object module obtains the 
absolute address of a Global Offset Table (GOT) in the module using relative branch and link 
instructions through the computer's link register. A dynamic linker constructs a Procedure 
Linkage Table (PLT) and a pointer table for an object module in a process memory image in 
which space is allocated for the PLT, but the PLT is not initially provided. The pointer table 
stores absolute addresses of external functions that cannot be reached by relative branching from 
the module. The PLT receives calls to these functions, gets the absolute addresses from the 
pointer table and branches to the absolute addresses of the functions. The PLT also receives 
calls to functions that can be reached by relative branching from the module, and causes relative 
branching to the functions. 

Zucker sets forth that a binary application object file program is configured in an 
Executable and Linking Format (ELF). More specifically, Zucker sets forth; 

The object program 60 comprises an ELF header 64 that specifies the number and sizes 
of the sections of the program 60, in addition to other information required by the 
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operating system 48. A section header table 66 is also provided, including information 
required to locate all of the sections of the file 60. 

The actual text (program instructions) and data of the program are provided in a number 
of discrete sections, designated as 68 1 to 68#. A dynamic section 70 contains dynamic 
linking information for use by the dynamic linker 54 (Zucker Col. 8, lines 28 -39). 

In general, neither Chen nor Zucker does not disclose or suggest method of producing a 
binary code file where the binary code file includes binary code instruction and compiler 
annotation where the compiler annotation is an ELF section, as substantially required by each of 
the independent claims. The ELF header 64 of Zucker neither teaches nor suggests the claimed 
binary code file having both binary code instructions and compiler annotation which is an ELF 
section. 

More specifically, Chen and Zucker, taken alone or in combination, do not teach or a 
method of producing a binary code file which includes compiling a plurality of source code 
instructions, and outputting a plurality of binary code instructions and compiler annotation 
wherein the plurality of binary code instructions is executable by a processor of a computer 
system and are an executable and linking format (ELF) binary code file and the compiler 
annotation is an ELF section, all as required by claim 1 . Accordingly, claim 1 is allowable over 
Chen and Zucker. Claims 2 - 7 depend from claim 1 and are allowable for at least this reason. 

Chen and Zucker, taken alone or in combination, do not teach or suggest a method of 
translating a source binary code file which includes translating a plurality of source binary code 
instructions utilizing compiler annotation and the outputting a plurality of target binary code 
instructions wherein the plurality of source binary code instructions are an executable and 
linking format (ELF) binary code file and the compiler is an ELF section and the plurality of 
target binary code instructions is executable by a processor of a computer system, all as required 
by claim 8. Accordingly, claim 8 is allowable over Chen and Zucker. Claims 9-15 depend 
from claim 8 and are allowable for at least this reason. 

Chen and Zucker, taken alone or in combination, do not teach or suggest a binary code 
file which includes a plurality of binary code instructions and compiler annotation where the 
plurality of binary code instructions are an executable and linking format (ELF) binary code file 
and the compiler annotation is an ELF section, all as required by claim 16. Accordingly, claim 
16 is allowable over Chen and Zucker. Claims 17-20 depend from claim 16 and are allowable 
for at least this reason. 
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Chen and Zucker, taken alone or in combination, do not teach or suggest an apparatus for 
producing a binary code file which includes means for outputting a plurality of binary code 
instructions and compiler annotation wherein the plurality of source binary code instructions are 
an executable and linking format (ELF) binary code file and the compiler annotation is an ELF 
section, all as required by claim 21. Accordingly, claim 21 is allowable over Chen and Zucker. 
Claims 22 - 25 depend from claim 21 and are allowable for at least this reason. 

Chen and Zucker, taken alone or in combination, do not teach or suggest an apparatus for 
translating a source binary code file which includes means for translating a plurality of source 
binary code instructions utilizing compiler annotation, and means for outputting a plurality of 
target binary code instructions wherein the plurality of source binary code instructions are an 
executable and linking format (ELF) binary code file and the compiler annotation is an ELF 
section all as required by claim 26. Accordingly, claim 26 is allowable over Chen and Zucker. 
Claims 27-30 depend from claim 26 and are allowable for at least this reason. 

Chen and Zucker, taken alone or in combination, do not teach or suggest an apparatus for 
producing a binary code file which includes instructions stored on a computer readable medium 
to compile a plurality of source code instructions, and output a plurality of binary code 
instructions and compiler annotation wherein the plurality of source binary code instructions are 
an executable and linking format (ELF) binary code file and the compiler annotation is an ELF 
section, all as required by claim 3 1 . Accordingly, claim 3 1 is allowable over Chen and Zucker. 
Claims 32 - 35 depend from claim 31 and are allowable for at least this reason. 

Chen and Zucker, taken alone or in combination, do not teach or suggest an apparatus for 
translating a source binary code file which includes instructions stored on a computer readable 
medium to translate a plurality of source binary code instructions utilizing compiler annotation, 
and output a plurality of target binary code instructions wherein the plurality of source binary 
code instructions are an executable and linking format (ELF) binary code file and the compiler 
annotation is an ELF section, all as required by claim 36. Accordingly, claim 36 is allowable 
over Chen and Zucker. Claims 37-40 depend from claim 36 and are allowable for at least this 
reason. 



In view of the arguments set forth herein, the application is believed to be in condition for 
allowance and a notice to that effect is solicited. Nonetheless, should any issues remain that 
might be subject to resolution through a telephonic interview, please telephone the undersigned. 



I hereby certify that this correspondence is being is being 
deposited with the United States Postal Service as First Class Mail 
in an envelope addressed to: Mail Stop AF, COMMISSIONER 
FOR PyUWTS, PO^ox 1450, Alexandria, VA 22313-1450, on 
Septeml ir 21, 2005j 




RogtoectfullY submitted, 





A. Terrile 
Attorney for Applicant(s) 
Reg. No. 32,946 



